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(57) A method^ system, and apparatus are provided 
for converting numbers between different units of meas* 
urement. When a string of text is entered into an appli- 
cation program, the string is emalyzed to determine 
whether the string of text includes a number having an 
associated unit name. If the string of text includes a 
number having an associated unit name, the number is 
semanticaily labeled with schema information that iden- 
tifies the unit name as a source unit of measurement. 



When a selection Is received of the number or an indi- 
catton that the number is labeled with schema informa- 
tion, a list of actions may be provided Identifying con- 
version options available for the number. One of the con- 
version options may then be sefected resulting in the 
conversion of the selected number to the destination 
unit of measure identified by the selected action. The 
converted number may then be inserted into the string 
of text to replace the selected number along with a unit 
name corresponding to the destir^tion unit of measure. 
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Description 
Technical Field 

[0001] Embodiments of the present invention relate to 
the field of unit measurement conversion. More partlc- 
ularty, embodiments of the Invention relate to the fiekJ 
of converting numbers between measurement systems 
based upon semanltcally labeled strings. 

Background of the Invention 

[0002] As a result of the advent and explosion of the 
internet and the World Wide Web ("Web"), computer us- 
ers today frequently receive electronic documents from 
other users located In countries throughout the world. 
Electronic documents sudi as these often include num- 
bers expressed in a unit of measurement utilized in the 
sender's particular country. For Instance, users located 
in the United States are likely to express numbers in the 
Imperial system of measurenDent (e.g. Inches, feet, 
etc.), while European users are likely to express num- 
bers in the Metric system of measurement (e.g. centim- 
eters. kik>meters. etc.). 

[0003] When users receive electronic documents 
having numbers expressed in measurement systems 
other than the system used In their native country, users 
may need to convert the numt»ers to their local meas- 
urement system to understand the meaning of the 
number For instance, a user may want to convert a 
numt>er expressed in degrees Fahrenheit, which is a 
unit of measure for temperatures commonly used in the 
United States, to degrees Celsius, which is a unit of 
measure for temperatures commonly used in Europe. 
However, converting numbers between measurement 
systems in this manner has heretofore been difficult tor 
a user to accomplish easily. 
[0004] Prevk>usly, If a user wanted to convert a 
number contained In an electronic document, such as a 
word processing document, t)etween measurement 
systems, the user would first have to copy the number 
to be converted to a clipboard. The user would then 
paste the number into an external program or Web site 
capable of converting the number to the desired desti- 
nation unit of measure. Once the external program or 
Web site had completed the conversion, the user may 
copy the converted number to the cfipboard and then 
paste the converted number back into the electronic 
document Although systems such as these do allow a 
user to convert a number between measurement sys- 
tems, these systems can be difficult for to use because 
of the large number of steps required to complete the 
conversion. Moreover, these previous solutions require 
the user to perfon7> the conversion using the user Inter- 
face language of the conversion program or Web site. 
This can be extremely frustrating for a user that does 
not understand the language of the conversion program 
or Web site. 



[0005] Therefore, in light of the above, there is a need 
for a method, system, and apparatus for easily convert- 
ing numbers between measurement systems that do not 
require a user to utilize an external applk^tion or Web 
5 site to convert numbers between measurement sys- 
tems. Moreover, there Is a need for a method, system, 
and apparatus for converting numbers between sys- 
tems of measure that can present conversion options to 
the user in a user-selected user interface language. 

10 

Summary of the Invention 

(0006] Embodiments of the present invention solve 
the above-described problems by providing a method, 

IS system, and apparatus for easily converting numbers 
between measurement systems and units that do not 
require the use of an external application or Web site to 
convert the numbers, f^reover, embodiments of the 
present invention provide a method, system, and appa- 

20 ratus tor converting numbers between units that can 
present conversion options to the user in a user-select- 
ed Interface language. Moreover, emtKXJiments of the 
inventten provide an extensible architecture through 
which a user may add conversion rules that enable con- 

25 version of numbers between measurement systems not 
initially supported. 

[0007] According to one actual embodiment of the 
present invention, a method is provided for converting 
a number between measurement systems In a system 

30 for creating and editing an electronic document. Accord- 
ing to this embodiment of the invention, sofhvare mod- 
ules are executed in conjunction with a software appli- 
cation for creating and editing an electronic document 
that allow the convenient conversk>n of numbers t>e- 

35 tween measurement units. When a user types a string 
of text, such as a paragraph Into the software applica- 
tion, the string is analyzed to detemnine whether the 
string of text Includes a number having an associated 
unit name. For instance, a user may type the number 

4o "lO" and the associated unit name "km", for kilometers, 
if the string of text includes a number having an associ- 
ated unit name, the number is semanticaify labeled with 
schema information that identifies the unit name as a 
source unit of measure. For instance, if a string of text 
includes the number MO" foflowed by the unit of meas- 
ure 'km', schema information will be associated with the 
number indicating that the number Is expressed with a 
source unit of measure. 

[OOOS] Once a number having an associated unit 
50 name has been identified within a string of text, such as 
a paragraph, the application may display an Indication 
to the user that the number has been semantk;ally la- 
beled. This indication also Identifies to the user that ac- 
tions may be performed on the number. When a selec- 
ts tlon is received of the number or the indication, a list of 
actions may be provided to the user identifying conver- 
sion options available for the number. For instance, if 
the identified number includes an associated unit name 



3 EPi: 

•m', for meters, an ac\k>n menu Item may be displayed 
to the user for cor)verting Uie number to feet or yards. 
Other types of conversion cations may also be present- 
ed to the user for converting the number. 
[0009] According to one embodtment of the invention, 
a current user interface language setting for the appfi* 
cation program is detenmined prior to providing the list 
of actions to the user. When the user selects the list of 
actions, the available actions are displayed to the user 
in a language specified by the current user interface lan- 
guage setting. In this manner, the user Is always pre- 
sented the conversion options In the current user inter- 
face language. Actions may also be included in the list 
of actions only for conversions supported for the current 
user interface language setting and may also be speci- 
fled as being enabled for use with all user interface lan- 
guages. 

[0010] After the list of actions has been displayed to 
the user, a selection of one of the actions may be re- 
ceived. In response to receiving the selecticHi of a con- 
version action, a converted number may be generated 
by converting the selected number to the destination 
unit of measure identified by the selected action. Once 
the conversion is completed, the converted number and 
Its associated unit name may be inserted into the string 
of text to replace the selected number and Its associated 
unit name. According to various emt>odiments of the 
present invention, a document object model supported 
by the application program may be utilized to insert the 
converted number into the string of text. Alternatively, 
the converted number may be displayed to the user. 
[0011] According to another embodiment of the 
present Invention, a system Is provided for converting a 
number between measurement systems. According to 
this embodiment of the invention, the system Includes 
a recognizer plug-in capable of receiving a portion of an 
electronic document as a string of text from an applica- 
tion program. For Instance, the recognizer plug-in may 
receive a paragraph of text from an appHcation program 
as It is typed by the user. Once the recognizer plug-in 
has received the string of text, the recognizer plug-in 
analyzes the string of text to determine whettier the 
string of text includes a number having an associated 
unit name, if the string of text includes a number having 
an associated unit name, the recognizer plug-in seman- 
ticalty labels the number with schema information iden- 
tifying the unit name as a source unit of measure and 
identifying the language used to express the string of 
text. This infonnatlon is then passed by the recognizer 
plug-in bacit to the application program. 
[0012] According to one embodiment of the invention, 
the system also includes an application program for cre- 
ating and editing an electronic document. For instance, 
the application program may comprise a word proces- 
sor, a spreadsheet application program, an e-mail ap- 
plfcation which includes editing functions, or other types 
of application programs for creating and editing elec- 
tronic documents. According to this embodiment of the 
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invention, the application program is capable of display- 
ing the string of text along with an indication that the 
nun)ber has been semanticatly labeled by the recogniz- 
er plug-In. This Mication may comprise a user Interface 
5 object for indicating to a user that the number has been 
semanticafly labeled and that conversion actions may 
t>e pertomfted on the number. 
[0013] The application program may also be opera- 
tive to receive a selection of the number or the indication 

10 and to provide a list of actions that may be perfomned 
on the number to convert the number to another meas- 
urement unit. The application may then receive the se- 
lection of one of the list of actions and provide the se- 
lection and the number to an action plug-in. 

IS [001 4] The system eJso includes an action plug-In that 
is capable of generating a converted number by con- 
verting the eelected number to the destination unit of 
measurement identified by action selected from the list 
of actions. The action plug-in Is also operative to replace 

20 the selected number and its associated unit name with 
the converted number and its associated unit name in 
the string of text. According to one actual embodiment 
of the Invention, the action plug-in may replace the 
number with the converted numl>er in the string of text 

25 by accessing a document object model provided by the 
application program. Alternatively, the converted 
number and its associated unit name may be displayed. 
[0015] According to various embodiments of the 
present Invention, the system provided herein may also 

00 include an action plug-in that is operative to register with 
the apprication program prior to pertomilng any conver- 
sion functions. As a part of the registration procedure, 
the action plug-in may provide the list of actions that may 
be pertormed on the number to convert the number to 

3s another measurement system to the application pro- 
gram. Moreover, when creating the list of actions, the 
action plug-in may detennine a cunent user intertace 
language setting for the application program and gen- 
erate the action menu Items In a language specified by 

40 the current user interface language setting. Additionally, 
the action plug-in may also consult a conversion settings 
file to generate action menu Items for each source unit 
name enabled for use with all enabled languages and 
for each source unK name enabled for use with the cur- 

45 rent user interface language. The contents of the con- 
version settings file may be modified by a user to enable 
conversion between measurement systems other than 
those initially defined in the conversion settings file. 
[0016] Other embodiments of the present invention 

so provide a computer-controlled apparatus and a compu- 
ter-readable medium for converting numbers between 
measurement systems based on semantically labeled 
strings. These and other details regarding the various 
emt)odlments of the Invention will become more appar- 

55 ent from the detailed description that follows. 



5 



EP 1 361 523 A2 



6 



Brief Description of the Dravrtngs 
[0017] 

FIQURE 1A Is a block diagram showing the archi- 
tecture of a personal computer that provides an Il- 
lustrative operating environment for embodiments 
of the present invention; 

FIQURE IB is a block diagram showing the fomnat 
and contents of a conversion settings fBe utf Hzed In 
various embodiments of the present invention to de- 
fine available conversions; 
FIQURE 2 is a block diagram that shows a software 
architecture for recognizing, labeling, and perform- 
ing actions on recognized strings of text according 
to various embodiments of the present invention; 
FIGURES 3A-3D are screen diagrams showing 
screen displays Including an actton menu for con- 
verting numbers between measurement systems 
provided by various embodiments of the present In- 
vention; 

FIQURE 4 is a flow diagram showing an illustrative 
routine for registering an action pfug-in with an ap- 
plication program according to one actual embodi- 
ment of the present invention; 
FIGURE 5 Is a flow diagram showing an illustrative 
routine for processirtg a siring input provkied at an 
applteation program according to one actual em- 
bodiment of the present Invention; 
FIQURE 6 is a flow diagram illustrating the opera- 
tion of a recognizer plug-in software module provid- 
ed according to one actual embodiment of the 
present invention; 

FIGURE 7 is a flow diagram illustrating a routine for 
processing the selectk>n of a semantically catego- 
rized number according to one actual err^odiment 
of the present invention; and 
FIGURE 8 is a flow diagram showing a routine for 
executing an action plug-In for converting numbers 
between measurement units according to one ac- 
tual embodiment of the present invention. 

Detailed Description of an Illustrative Embodiment 

[0018] As described briefly above, embodiments of 
the present Invention provide a method, system, appa- 
ratus, and computer- readable medium for converting 
numbers between units of measure. In the following de- 
tailed description, references are made to the accom- 
panying drawings that form a part hereof, and in which 
are shown by way of illustration specific embodiments 
or oxamples. These embodiments may be combined, 
other embodiments may be utilized, and structural 
changes may be made without departing from the spirit 
and scope of the present Invention. The following de- 
tailed description is, therefore, not be taken in a limiting 
sense, and the scope of the present invention is defined 
by the appended claims and their equivalents. 



[0019] Referring now to the drawings, in which like nu- 
merals represent like elenf>ents through the several fig- 
ures, aspects of the present Inventton and the Illustrative 
operating environment will be described. FIGURE 1A 
5 and the following discussion are Intended to provkle a 
brief, general description of a suitable computing envi- 
ronment In which the invention may be implemented. 
While the Invention will be described In the general con- 
text of prog ram modules that execute in conjunction with 
10 an application program that runs on an operating system 
on a personal computer, those skilled In the art will rec- 
ognize that the invention may also be implemented in 
combination with other program modules. Additional as- 
pects of an illustrative operating environment and soft- 
is ware architecture for implennenting the various embod- 
iments of the present invention are described In U.S. 
Patent Applteation No. 09/588,41 1 , entitled "Method and 
System for Semantk^ally Labeling Strings and Providing 
Actions Based on Semantk:aily Labeled Strings*, which 
is expressly incorporated herein by reference. 
[0020] Generally, program modules Include routines, 
programs, components, data structures, and other 
types of structures that perform particular tasks or im- 
plement particular abstract data types. Moreover, those 
skilled in the art will appreciate that the invention may 
be practk:ed with other computer system configurations, 
including hand-held devices, multiprocessor systems, 
nvcroprocessor-based or programmable consumer 
electronics, mink?ompulefs, mainframe computers, and 
the Pike. The invention may also be practiced in d'^rib- 
uted computing environments where tasks are per- 
formed by remote processing devices that are linked 
through a communications network. In a distributed 
computing environment, program modules may be k>- 
cated in both local and remote memory storage devices. 
[0021] Tuming now to FIQURE 1A, an illustrative 
computer archit^ture for a personal computer 2 for 
practicing the various embodiments of the invention will 
be described. The computer architecture shown in FIG- 
URE 1A illustrates a conventional personal computer, 
Including a central processing unit 4 ('CPU"), a system 
memory 6. including a random access memory 8 
("RAM") and a read-only memory ("ROM") 10, and a 
system bus 12 that couples the men>ory to the CPU 4. 
A basic Input/output system containing the basic rou- 
tines that help to transfer information between elements 
within the computer, such as during startup. Is stored in 
the ROM 1 0. The personal computer 2 further includes 
a mass storage device 14 for storing an operating sys- 
tem 16, application programs, such as the application 
program 205, and data. 

[0022] The mass storage device 14 is connected to 
the CPU 4 through a mass storage controller (not 
shown) connected to the bus 12. The mass storage de- 
vtoe 14 and its associated computer-readable media 
provide non- volatile storage for the personal computer 
2. Although the description of computer- readable media 
contained herein refers to a mass storage device, such 



25 



30 



35 



40 



45 



SO 



7 EP 1 361 523 A2 8 



as a hard disk or CD-ROM drivo, it should be apprecl- 
ated by those skilled in the art that computer-readable 
media can be any available media that can be accessed 
by the personal computer 2. 
[0023] By way of example, and not limitation, compu- 
ter-readable media may comprise computer storage 
media and communication media. Computer storage 
media includes volatile and non-volatile, removable and 
non*removable media implemented in any method or 
technology for storage of information such as computer- 
readable instructions, data structures, program mod- 
ules or other data. Computer storage media includes, 
but Is not limited to. RAM, ROM, EPROM, EEPROM. 
flash memory or other solid state memory technology. 
CE>ROM. DVD, or other optical storage, magnetk: cas- 
settes, magnetb tape, magnetic disk storage or other 
magnetic storage devtoes, or any other medium which 
can be used to store the desired information and which 
can be accessed by the computer. 
[0024] According to various embodiments of the in- 
vention, tt>e personal computer 2 may operate in a net- 
worked environment using logical connectbns to re- 
mote computers through a TCP/IP network 18. such as 
the internet. The personal computer 2 may connect to 
the TCP/IP network 18 through a network Interface unit 
20 connected to the bus 12. It should be appreciated 
that the network interface unit 20 may also be utilized to 
connect to other types of networks and remote computer 
systems. The personal computer 2 may also Include an 
input/output controller 22 for receiving and processing 
input from a number of devices, including a keyt)oard or 
mouse (not shown). Similarly, an input/output controlter 
22 may provide output to a display screen, a printer, or 
other type of output device. 

[0025] As mentioned briefly above, a number of pro- 
gram modules and data files may be stored in the mass 
storage device 14 and RAM 8 of the personal computer 
2. Including an operating system 16 suitable for control- 
ling the operation of a networked personal computer, 
such as the WINDOWS XP operating system from MI- 
CROSOFT CORPORATION of Redmond. Washington. 
The mass storage device 14 and RAM 8 may also store 
one or more application programs. In particular, the 
mass storage device 14 and RAM 6 may store an appll- 
catk^n program 205 for creating and editing an electronk; 
document 24. For instance, the application program 205 
may comprise a word processing application program 
and the electronic document 24 may comprise a word 
processing document. The application program 205 
may also comprise a spreadsheet application program 
and the electronic document 24 cmiprise a spread- 
sheet. Similarly, the applfcation program 205 may com- 
prise an electronic mail application program and the 
electronic document 24 may comprise an electronic mail 
message. Application programs for creating and editing 
other types of electronic documents may also be used 
with the various emtxidfments of the present invention. 
[0026] Emtradiments of the present invention provide 



program modules for use in conjunction wfth the appll- 
catk)n program 205 that convert numbers contained 
within the electronic document 24 between units of 
measure, also referred to hemin as measurement units 
s or measurement systems. In partknitar, embodiments of 
the Invention provide a recognizer plug-in 220 and an 
action plug-in 225. As will t>e described in greater detail 
below, the recognizer plug-in 220 recognizes numbers 
having an associated unit name contained within an 

10 electronic document 24 and labels the numbers with se- 
mantic information klentifying the unit name as a source 
unit of measure. The recognizer plug-In 220 then passes 
this informatton to the applteation program 205 for use 
by the action plug-In 225. The action plug-in 225 per- 

15 forms actions on the recognized numbers for converting 
between units of measure. The availat>l8 conversions 
are defined in the conversion settings file 28. Additional 
details regarding the conversion settings file 28 are de- 
8crft)ed below with reference to FIGURE IB. 

20 [0027] According to various embodiments of the 
present invention, the action plug-In 225 may also gen- 
erate a list of actions that may be performed on a given 
number. As a part of this process, the action plug-in 225 
may query language settings 26 of the application pro- 

25 gram 205 or operating system 16. The language set- 
tings 26 specify the current user interface language. The 
list of actions may then be created In the current user 
interface language. Moreover, the action piug-in 225 
may also consult the conversion settings file 28 to gen- 

30 erate action menu Items for each source unit name en- 
abled for use with all enabled languages and for each 
source unit name enabled for use with the current user 
Interface language. Additional details regarding the op- 
eration of the recognizer plug-in 220 and the action plug- 

35 In 225. including the use of the conversk>n settings fife 
28 and the language settings 26. will be described in 
greater detail below. 

[0028] Referring now to FIGURE 1 B, various aspects 
of the conversion settings file 26 will be described. As 

40 discussed briefly above, the conversion settings file 28 
is utilized by both the recognizer plug-In 220 and the 
action plug-in 225. In particular, the recognizer p(ug-in 
220 utilizes portions of the conversion settings file 28 to 
determine the source unit names that shouki be recog- 

45 nized within a string of text, and the actbn plug-in 225 
utilizes the conver$k>n settings file 28 to create the ac- 
tion menus that should be presented to the user and to 
actually perform conversions. Additional details regard- 
ing the use of the conversion settings file 28 by the rec- 

50 ognizer plug-in 220 and the action plug-in 225 will be 
described in greater detail below. 
[0029] As shown In FIGURE 1B, the conversion set- 
tings file 28 comprises a data file having fields 50A-50J. 
The fieW 50A contains a locale identification ("LCID") 

55 number for whtoh a partkjular conversion should be en- 
abled. As known to those skilled In the art, when used 
in conjunction with the WINDOWS XP operating system 
from MICROSOFT CORPORATION of Redmond. 
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Washington, the LCID is an identification number used 
to identify locales and languages. The LCID Is used 
herein to ensure that conversion options will be present- 
ed to the user only for conversione that are enat>led for 
use with the currently enabled language. Alternatively, s 
the Held 50A may Include the phrase 'ALL*, thereby en* 
abling the conversion for use with all enabled languag- 
es. Additional details regarding the use of the field 50A 
will be described below. 

[0030] The conversion settings file 28 also includes a 
field SOB representing the source unit name. The source 
unit name is the name of the source unit of measure that 
is associated with a recognized number. The recognizer 
plug-in 220 uses the field 506 to tdentffy those source 
unit names that it should recognize. The conversion set- is 
tings file 28 also Includes a field 500 that Includes a 
source description corresponding to the source unit 
name identified in the field 506. The contents of the field 
50C may be localized for a particular locale. The con- 
version settings file 28 also includes a field SOD that in- 20 
dicates whether a space is located between the source 
unit name and number. Some regional fomriats utilize a 
space between a number and a unit name while others 
do not. The field SOD is therefore utilized by the recog- 
nizer plug-in 220 to recognize numbers expressed using 
either format. The conversion settings file 28 also in- 
dudes a field 50E that defines whether the case of the 
source unit name should be considered by the recog- 
nizer plug-in 220. 

[0031] The conversion settings file 28 also includes 30 
the field 50F which contains data identifying the desti- 
nation unit name and a field 50O which contains data 
identifying the destination description. As with the field 
50C, the field SOG may be localized for a particular lo- 
cale. A field 50H is also included that indicates whether 3S 
a space should be placed between the destination 
number and its associated unit name in the conversion 
result. The field SOH is utilized by the action plug-in 225 
when formatting conversion results. 
[0032] The conversion settings file 28 also indudes a ^ 
field 501 uidicating the number of decimal places that 
should be utilized when rounding the converted result. 
The field 501 may be changed foreach conversion. Typ- 
ically, the rounding precision value contained in field 501 
Is adjusted for conversions where the destination value 
is much larger or much smaller than the source number. 
[0033] The conversion settings file 28 also Includes a 
field 50J which defines the conversion ratio or formula 
reference that should be utilized for a particular conver- 
sion. Where a conversion Is perfomied by multiplying by so 
a coefficient, the field 50J contains the coefficient. 
Where a conversion (s perfonned utilizing a more com- 
plex equation, the field SOJ may include a formula ref- 
erence to the appropriate formula. For Instance, the field 
SOJ may include a reference to a formula for converting 55 
Celsius values to Fahrenheit vafues. such as *CTOF*. 
Other types of fonnula references may also be provided 
for performing more complex conversions. 



[0034] The conversion settings file 28 shown in FIG- 
URE 16 includes several illustrative conversion entries 
52A-52E. The entry 52A corresponds to a conversion 
from kilometers to miles and is enabled for all languag- 
es. The entry 526 oon^esponds to a conversion from de- 
grees Celsius to degrees Fahrenheit and Is also enabled 
for all languages. The entries 52C-S2D convert between 
Swedish long' miles and kilometers and are only ena- 
bled when the active user interface language corre- 
sponds to the LCID '1054." The entry 52E corresponds 
to a conversion from kilometers to yards and is also en- 
abled for all languages. 

[0035] It should be appreciated by the reader that the 
entries 52A-52E are merely illustrative examples of the 
types of conversions that may be defined in the conver- 
sion settings file 28 and that other types of conversions 
may be simllarfy defined. In particular, conversions may 
be defined between miles and kilometers, inches and 
centimeters, millimeters and Inches, feet and centime- 
ters, meters and feet, yards aruJ meters, acres and hec- 
tare, U.K. pints and liters. U.S. pints and liters, titers and 
gallons, ounces and deciliters, quarts and liters, pounds 
and kHograms, miles per hour and kilometers per hour, 
and other measurement units. Moreover, it sfiould be 
appreciated that additional conversions may be defined 
by adding an appropriate entry to the conversion set- 
tings file 28 defining the new converston. 
[0035] Referring now to FIGURE 2, an Illustrative soft- 
ware architecture for use in conjunction with the various 
embodiments of the present invention will be described. 
The architecture shown in FIGURE 2 includes an appli- 
cation program 205, such as a word processor applica- 
tion program, a spreadsheet application program, or 
other type of application program for creating and edit- 
ing electronic documents. The apptk:atlon program 205 
may also comprise a Web browser. 
[0037] The application program 205 is able to com- 
munk^ate with a recognizer dynamically linked library 
("DLL") 21 0 and an action DLL 21 5, As will be described 
in greater detail below, the recognizer DU. 21 0 controls 
one or more recognizer plugWns 220A-220N and the ac- 
tion DLL 2 1 5 controls one or more action plug-ins 225A- 
225N. 

[0038] According to one embodiment of the invention, 
the recognizer plug-ins 220A-220N and the action plug- 
ins 225A-225N are automatbn servers. Automation 
servers are well-known software components that are 
assembled into programs or add functionality to existing 
programs running on the WINDOWS XP operating sys- 
tem from ly/IICROSOFT CORPORATION of Redmond, 
Washington. Automation servers may be written in a va- 
riety of computing languages and can be plugged and 
unplugged from a program at runtime without having to 
recompile the program. 

[0039] The recognizer D LL 2 1 0 handles the distrilxj- 
tion of text strings from an electronic document being 
edited by the application program 205 to the individual 
recognizer plug-fns 220A-220N. The recognizer plug- 
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ins 220A-220N recognize particular strings In an eie> 
tronic document, such as a word processing document 
or a spreadsheet document The recognizer plug-ins 
220A-220N may be packaged with the application pro- 
gram module 205 or they may be written by third partfes 
to recognize particular strings of interest. Typically, the 
recognizer DLL 210 passes strings to the recognizer 
plug-Ins 220A-220N in single paragraphs or cell value 
increments. However, strings may be passed to the rec- 
ognizer plug-Ins 220A-220N in other sizes and fomfiats. 
[0040] As part of recognizing certain strings as includ- 
ing semantic information, the recognizer plug-ins 220 A- 
220N detenfnine which strings are to be labeled and how 
they are to be labeled. After receiving these results from 
the various recognizer plug-Ins 220, the recognizer DLL 
210 sends semantic categories to the application pro- 
gram module 205. According to one actual embodiment 
of the invention, a recognizer plug-in 220 is provided for 
recognizing strings as containing numbers having an 
associated unit name. According to this embodiment of 
the invention, the semantic category comprises schema 
information that identifies the unit name as a source unit 
of measure. The schema Information may also include 
information Identifying the language in which the string 
of text is expressed. This Information is returned to the 
recognizer DLL 21 0 by the recognizer plug-in 220 along 
with other Information that n^ay be utilized by a corre- 
sponding action plug-In 225, such as a copy of the 
number, the source unit name, and the language that 
the string ot text is expressed in. Additionally, the rec- 
ognizer plug-in 220 may return information identifying 
the location of the number wrth^ the text string, Includ- 
ing the length of the text string and the character number 
of the first letter of the number. 
[0041] It should be appreciated that each of the rec- 
ognizer plug-ins 220A-220N are executed separately. 
The recognizer DLL 21 0 is responsible for handling the 
asynchronidty that results from different recognizer 
plug-ins 220A-220N returning results at different times. 
In this manner, various types of data may be recognized 
within a text string and cfifferent actions provided for 
each semantlcally labeled string. Additional details re- 
garding the operation of the recognizer plug-in 220 for 
recognizing numbers will be described below with refer- 
ence to FIGURES 3-e. 

[0042] After a string is labeled by a recognizer plug- 
in 220A-220N, schema Information is sent to the appli- 
cation program module 205. A user of the application 
program nrK>dule 205 may then execute actions that are 
associated with the schema information on the recog- 
nized string. The action DLL 215 manages Ihe action 
plug-ins 225A-225N that are executed in order to per- 
form the actions. As with the recognizer plug-ins 220A- 
22N, the action plug-ins 225A-225N may be packaged 
with the application program module 205 or written by 
third parties to perform particular actions that are of in- 
terest. The action plug-ins 225A-225N provide possible 
actions to be presented to the user based upon the 



schema Infonnation. or type label, associated with the 
string. As will be described in greater detail below, the 
list of actions provided to the user Is dynamically gener- 
ated for each schema type. This information is then pro- 

s vided to the appllcatton program 205 which displays the 
list of actions to the user when the string is selected. 
[0043] After an action has been chosen from the list 
of actions, the action DU. 2 1 5 manages the appropriate 
action plug-in 225A-225N and passes the necessary in- 

10 formation between the action plug-in and the application 
program module 205 so that the action plug-in may ex- 
ecute the desired action. Typically, the appficatlon pro- 
gram module 205 sends the action DLL 215 an automa- 
tion request to invoice the action the user has selected. 

IS As will be described in greater detail below, according 
to one embodiment of the invention, an action plug*in 
225 is provided that converts recognized numbers to 
other units of measure. Addition details regarding the 
operation of the action plug-in 225 and the schema rrv 

20 formation utilized to identify different source unit names 
will be described in greater detail below with reference 
to FIGURES 3-8. 

[0044] Referring now to FIGURES 3A-3D, an illustra- 
tive user interface provided by the various emt>odiments 

25 of the present invention will be described. As shown In 
FIGURE 3A, a number 32 including an associated unit 
name may be typed by a user into an application pro- 
gram 205, such as a word processor, as a part of a string 
of text. Once the user has provided the string of text, the 

so string of text is prt>vided to a recognizer plug-in 220 that 
recognizes numbers contained within the string of text, 
such as the number 32. The number 32 having an as- 
sociated unit name Identified by the recognizer plug-In 
220 Is identified to the application program module as a 

35 type of semantic information upon which actions may 
be performed. Therefore, the applicdtion program mod- 
ule 205 provides en indication to the user that actions 
may be performed on the numlwr 32, This indication 
may be provided to the user by highlighting the number 

40 32 or providing a u ser Interface indication 34 in proximity 
to the numt»er 32. 

[0045] When the number 32 or the indication 34 is se- 
lected by a user, a list of actions is displayed that may 
be performed on the number to convert the number to 

45 another unit off measure. This list off actions may com- 
prise a dropdown menu 36 having one or more menu 
Items corresponding to the list of actions that may be 
performed on the number 32. According to one embod- 
iment of the invention, the contents of the dropdown 

so menu 36 may be displayed in one of many different lan- 
guages. The language in which the dropdown menu 36 
is displayed is based on a current interface user lan- 
guage for the appllcatton program module 205 or the 
operating system 16. In this marwier, international users 

55 throughout the worid will be displayed a dropdown menu 
36 In their currently installed and active user interface 
language. 

[0046] As shown in FIGURE 3A, the dropdown menu 
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36 includes another indication of the number 32 to be 
converted. The dropdown menu 36 also includes a list 
of actions 38 that may be performed to convert the 
number 32 to other measurement systems. According 
to one embodiment of the Invention, the list of actions 5 
38 displayed in the dropdown menu 36 is limfted to con- 
version options specified for use with the currently ena- 
bled user interface language on the personal computer 
2. In this manner, actions for converting numbers not 
relevant to the currently enabled language of the per* io 
sonal computer 2 will not be shown in the dropdown 
menu 36. 

[0047] As shown in FIGURE 3A, the application pro* 
gram rrHxiule 205 also adds menu Items 44A and 448 
to the dropdown menu 36. The selection of item 44A is 
removes the semantic labeling from the selected text. 
Other recognized text in the same (or other) documents 
will remain labeled, and newly typed text wHi still be sub- 
ject to continued recognition and labeling. The selection 
of item446 provides a list of user seiectat>le preferences 20 
defining the operation and behavior of the recognizer 
and action plug-Ins. 

[0048] As described briefly above, when a number 32 
having an associated unit name is recognized by the 
recognizer plug-in 220, the number 32 Is labeled with 25 
schema mfomnation identifying the associated unit 
name as a source unit of measure. Additionaily, the lan- 
guage of the string of text may also be Identified In the 
schema Information. This schema information is then re- 
turned to the application program 205 and is utilized by so 
the action ptug-in 225 to determine the appropriate list 
of actions 38 that should be included in the dropdown 
menu 36. In this manner, only conversion operatlor)s 
consistent with the source unit of measure and the lan- 
guage used to express the string of text are provided to 35 
the user via the dropdown menu 36. 
[0049] The number 32 shown in FIGURE 3A Is ex- 
pressed in kilograms. Therefore, the dropdown menu 36 
includes actions in the list of actions 38 for converting 
the number 32 to pounds, and to stones and pounds. <o 
Similarly, the number 32 shown In FIGURE 38 Is ex- 
pressed in meters. Therefore, the dropdown menu 36 
includes actions in the list of actions 38 for converting 
the number 32 to feet end to yards. Likewise, the 
number 32 shown in FIG U RE 3D is shown degrees Cel- 
sius. Therefore, the dropdown menu 36 includes only 
an action for converting the number 32 from degrees 
Celsius to degrees Fahrenheit Also, the list of actions 
38 shown in FIGURES 3A, 3B, and 3D is displayed Eng- 
lish. It should be appreciated, however, that the drop- so 
down menu 36 would appear in another language if a 
language other than English was selected as the current 
user interface language on the personal computer 2. 
[0050] As shown in FIGURE 30, once the user has 
selected an action from the list of actions 38, the con- ss 
version of the number 32 Is performed according to the 
selected action. The converted number may then be dis- 
played to the user In a dialog box 37 as shown in FIG- 



URE 3C. Alternatively, the number 32 may be replaced 
In the string of text with the converted number and the 
unit name associated with the destination unit of meas- 
urement. The number 32 may be replaced in the string 
of text using a document object model provided by the 
application program 205. This process is described in 
greater detafl below. Additionally, as will be discussed 
in greater detail below, the application program 205 re- 
ceives most of the text shown in the dropdown menu 36 
from the action plug-in 225. This process occurs when 
the application program 205 is Initially executed and the 
action plug-In 225 registers itself wlU) the application 
program 205. Additional details regarding this registra- 
tion process will be described below with reference to 
FIGURE 4. 

[0051] Refening now to FIGURE 4, an Illustrative rou- 
tine 400 will be described for registering the number 
conversion software components with the application 
pn>gram 205. In particular, when the action plug-in 225 
and the recognizer plug-In 220 for converting numbers 
are first executed, they are registered with the applica- 
tion program 205. By registering with the application 
program 205. the application program 205 is made 
aware of the software components and enabled for use 
with the schema types recognized by the recognizer 
plug-in 220. Moreover, the action items to be displayed 
to the user corresporKfing to each schema type are also 
enumerated to the application program 205 so that the 
application program 205 can display the dropdown 
menu 36 when a number 32 or indicator 34 Is selected 
by a user. 

[0052] The routine 400 begins at block 402, where the 
cun^nt user Interface language Is identified. As dis- 
cussed briefly above, ihe current user interface lan- 
guage may be stored in the language settings 26 main- 
tained by the operating system 1 6 or the application pro- 
gram 205. Once the current user interface language has 
been identified, the routine 400 continues to blocic 404. 
At bJoci( 404, the action plug-in 225 consults the con- 
version settings file 28, and generates action menu 
items for defined conversions that are specified for op- 
eration with all languages. In particular, the action plug- 
in 225 creates action menu items for all defined conver- 
sions that include the phrase "AU." in the field 50A of 
the conversion settings file 28. The routine 400 then 
continues to block 406. 

[0053] At block 406, action menu items are also gen- 
erated for each defined conversion that has an entry in 
field 50 A con-esponding to the current user Interface lan- 
guage. In this manner, action menu items are generated 
only for those conversions enabled for use with all user 
inlertaoe languages and for those conversions enabled 
for use with the current user interiace language. It 
shoukj be appreciated that the action menu items are 
generated on a per source unit name basis. In this man* 
ner, many separate dropdown menus 36 may be gen- 
erated, one for each source unit name. Moreover, a sep- 
arate schema name is utilized for each source unit name 



15 



EP 1 361 523 A2 



16 



and current user interface language. In this manner, re- 
gardless of the source unit name or current user inter- 
face language, an appropriate dropdown menu 36 will 
be presented. 

[0054] From block 406, the routine 400 continues to 5 
block 408, where the action menu items for each sche- 
ma are returned to the application program 205. Accord- 
ing to one 6ml>odlment of the Invention, the application 
program 205 displays the dropdown menu 36 In re- 
sponse to the selection of a number 32 or an Indicator io 
34, However, it should be appreciated that the action 
plug-in 225 or other software component may be re- 
sponsible for the display of the dropdown menu 36. The 
routine 400 continues from block 408 to block 410, 
where it ends. is 
[0055] Tuming now to FIGURE 5, an lllustratWe rou- 
tine 500 will be described for processing the input of a 
new string at the application program 205. The routine 
500 begnis at block 502. where the applicatton program 
205 receives a new string, such as when a user enters 20 
a new paragraph into an electronic document or edits a 
prevk>usly entered paragraph. From block 502, the rou- 
tina 500 continues to block 504 where the appticatk>n 
program 205 passes the new string to the recognizer 
DLL 2 1 0. As described above, the recognizer DLL 210 25 
is responsible for communicating with the application 
program 205, managing the jobs that need to be per- 
formed by the recognizer plug-ins 220A-220M, receiving 
results from the recognizer plug-ins 220A-220N, and 
sending schema information to the application program 30 
module 205 for recognized numbers and source unit 
names. It shouki be understood that, in one embodiment 
of the invention, a paragraph Is passed to the recognizer 
DLL 210 at block 504. However, in altematlve embodi- 
ments, a sentence, the contents of a spreadsheet cell. 35 
a section of the document, the entire document, etc., 
may be passed to the recognizer DLL 210. In other 
words, it should tie appreciated that the embodiments 
of the present invention are not limited to simply passing 
a paragraph to the recognizer DLL 210. ^ 
[0056] From block 504, the routine 500 continues to 
block 506, where the recognizer DLL 210 passes the 
string to the recognizer plug-ins 220A-220N. The routine 
500 then continues to block 508 where the recognizer 
plug-ins are executed on the paragraph to recognize key *s 
words or characters within the string. In partkxjiar, the 
recognizer plug-In for converting numbers between 
measurement systems is executed on the string. An Il- 
lustrative routine descr93ing the operation of the recog- 
nizer plug-in for number conversion is descrit)ed below so 
with reference to FIGURE 6. 

[0057] At block 510, the results from the recognizer 
plug-in 220 are received at the recognizer DLL 21 0. The 
routine 500 then continues to block 512, where a deter- 
mination is made by the recognizer DLL 210 as to ss 
whether the paragraph has been edited since the string 
was transmitted to the recognizer plug-Ins 220A-220N. 
If the paragraph has been edited, the routine 500 returns 



to block 504, where the edited string is passed to the 
recognizer DLL 210. If the paragraph has not been ed- 
ited, the routine 500 continues to bkwk 514. where the 
recognizer DLL 2 10 sends the results received trom the 
recognizer plug-in 220 to the application program 205. 
The routine 500 then continues to block 516, where it 
ends, 

[0058] Refenring now to FIGURE 6, an illustrative rou- 
tine 600 will be described that Illustrates the operation 
of the recognizer plug-in 220for converting numbers be- 
tween units of measure according to one embodiment 
of the present invention. The routine 600 begins at block 
602, where a string of text Is received at the recognizer 
plug-in 220 from the recognizer DU. 210. The routine 
600 then continues to block 604, where a detenmlnatk)n 
is made as to whether the string of text contains a 
number. 

[0059] From block 604, the routine 600 continues to 
block 606, where a determtnatton Is nnade as to whether 
a number was found In the string of text. If no digits were 
found, the routine 600 branches from block 606 to bk)ck 
614, where It returns to block 510, shown in FIGURE 5. 
If, however, at btock 606, it Is detemnned that digits were 
found In the string of text, the routine 600 continues to 
bk)ck 608. 

[0060] At block 608, text located after the identified 
digits Is scanned to determine whether a source unit 
name is associated with the number. For example, the 
recognizer plug-in 220 may scan the text after the iden- 
tified digits for the source unit names "km", "lb", "mi", 
and other source unit names. The list of the source unit 
names that the recognizer plug-in 220 searches for Is 
defined by the field 508 of the conversion settings fife 
28. 

[0061] From block 608 the routine 600 continues to 
block 610 where a detennination is made as to whether 
a source unit name associated with the recognized 
numt>er was tocated. If no source unit name was found, 
the routine 610 branches to block 614, where it returns 
to block 51 0, shown In FIGURE 5. If a source unit name 
was found that Is associated with the recognized 
number, the routine 600 continues to block 612. 
[0062] At block 612, schema Informatkin is returned 
to the recognizer DU. 21 0. In particular, a schema name 
associated with the source unit nan^e and the currently 
enabled language is returned to the recognizer DLL21 0. 
Additionally, a 'property bag" may also be returned to 
the recognizer DLL 210. The property bag is an object 
which stores information about the recognized number 
that may be utOized by the action plug-in 225. For In- 
stance, the property bag may include a format number 
indicating generally which format the recognized 
number was written in. Additionally, an index to the rec- 
ognized number within the string of text may also be re- 
tumed to the recognizer DLL 210. All of the infomiation 
returned from the recognizer plug-in 220 to the recog- 
nizer DLL 210 may be subsequently passed to the ac- 
tion plug-in 225 and used in the conversion process. 
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Thl$ is descdbed In greater detail below wfth respect to 
FIGURES 7 and 8. From block 612, the routine 600 con- 
tinues to block 614, where it returns to block 510, shown 
in FIGURE 5. 

[0063] Referring now to FIGURE 7, an illustrative rou- 
tine 700 wKI be described for processing the selection 
of a semantk)al(y categorized number having an asso- 
ciated unit name. As discussed above, once a number 
has been recognized within a string of text by the rec- 
ognizer plug-In 220A as having an associated unit 
name, the number may be highlighted or an Indication 
may be provided to the user Indicating that the number 
has been recxignfzed and that actions may be performed 
on the number. Accordingly, at bkx;k 702, a detennlna- 
tion Is made as to whether the number or indicator has 
been selected by a user. If the number has not been 
selected, the routine 700 continues to block 714, where 
it ends. If. however, the number or Indk^ator has been 
sefected, the routine 700 continues to block 704. 
[0064] At block 704, the application program 205 dis- 
plays the list of actions associated with the schema cor- 
responding to the selected number. In this manner, the 
dropdown menu 36 described above with reference to 
FIGURE 3A is presented to the user. The routine 700 
then continues from block 704 to block 706, where a de- 
temnlnatlon Is made as to whether the user has selected 
one of the items from the list of actions. If the user has 
made the selection of a user interface item other than 
one of the items from the list of actions, the routine 700 
branches to block 710, where tiie list of actions is re- 
moved. If, however, the user does select one of the 
items from the list of actions, the routine 700 continues 
to block 708. 

[0065] At block 708, the application program 205 calls 
the action plug-in 225 corresponding to the appropriate 
schema type and indk;ates that an action item has been 
selected. The call from the application program 225 to 
the action ptug-ln 225 includes the schenui name cor- 
responding to the recognized number, the item number 
of the selected menu item, the name of the calling ap- 
plication program 205, a pointer Into an object model 
provided by the application program 205 for accessing 
the document 24, the property bag described at>ove vrith 
reference to FIGURE 6, and the text of the recognized 
number. The routine 700 then continues to block 712, 
where the action plug-in for converting numbers be- 
tween measurement units Is executed. An Illustrative 
routine for executing the action plug-In 225 for number 
conversion is described below with reference to FIG- 
URE 8. Once the action plug-tn 226 has completed its 
execution, the routine 700 continues from block 712 to 
block 714, where It ends, 

[0066] Referring now to FIGURE 8, an illustrative rou- 
tine 800 will be described for executing an action plug- 
in 225 for converting numbers between measurement 
systems. The routine 800 begins at block 802. where 
the action plug-in 225 receives a call from the action DLL 
215 indicating that the user has selected an action menu 



item. From bk)ck 802, the routine 800 cominues to block 
804, where the action plug-In 225 determines the actual 
value of the recognized number In view of a format as- 
sociated with the language in which the string containing 

s the numt>er is expressed. Tttis is necessary because 
numbers expressed in different languages may include 
separator characters that have different meanings in dif- 
ferent languages. For instance, a numt^er may be ex- 
pressed in French as M,729', while in English it would 

^0 be expressed as "1729." Therefore, at bkck 804, the 
action ptug-in 225 identifies the regional fonnat for the 
number from the language settings file 26 based on the 
language in which the number is expressed. Using the 
regional format, the actual value of the number can be 

IS determined. 

[0067] From block 804, the routine BOO continues to 
block 806. where the recognized number is converted 
to the destination unit of measure according to the se- 
lected action menu Hem. In particular, the value of the 
20 fieid 50J of the conversion settings file 28 for the select- 
ed conversion may be utilized to convert the recognized 
and selected numt>er. The vakie of the field 501 in the 
converston settings file 28 may also be utilized to round 
the converted number to the appropriate number of dig- 

25 its. 

[0068] From block 806, the routine 800 continues to 
block 808. where the converted number is formatted. 
The converted numt>er may be formatted according to 
the regional format specified in the language settings 

30 file 26. Moreover, the value of field 50K In the conversion 
settings file 28 may be utilized to format the spacing be- 
hAreen the converted number and the destination unit 
name. Other types of fomiatting may also be applied to 
the converted number. 

35 [0069] From block 808, the routine 800 continues to 
bkx^k 810 where the number in the string of text is re- 
placed with the converted number. According to one em- 
bodiment of the present invention, the replacement is 
made by accessing a document c^ject model provided 

^ by the application program 205. Through the document 
object model, the action plug-pn 225 can directly access 
the document 24 and make changes therein. Details re- 
garding the use of such a document object model are 
well known to those skilled in the art. Alternatively* the 

45 converted number and its associated unit name may be 
displayed to the user. From block 810, the routine 800 
continues to block 612. where It returns to block 714, 
described above with reference to FIGURE 7. 
[0070] Based on the foregoing, those skilled in the art 

so should appreciate that varkxis embodiments of the 
present invention provide a method, system, apparatus, 
and computer-readable medium for converting numbers 
between units of measure based upon semantlcaJly la* 
baled strings. The above specification, examples and 

S5 data provide a complete description of tiie manufacture 
and use of the composition of the invention. Since many 
embodiments of the invention can be made without de- 
parting from the spirit and scope of the invention, the 
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5. The method of Clafm 4. wherein replacing the 
nurnber and the associated unit name with the con- 
verted number and a unit name associated with the 
destination unit of measure comprises utilizing a 

s document object model provided by an application 
for editing the electronic document to replace the 
nuniber and the associated unit name with the con- 
verted number and a unit name associated wtth the 
destination unit of measure. 

10 

6. The method of Claim 6. wherein the list of actions 
comprises a dropdown menu having one or more 
menu items con^esponding to the list of actions that 
may be performed on the number to convert the 

15 number to the destination unit of measure. 

7. The method of Claim 6. further comprising: 

detemitntng a current user interface language 
20 setting for the application; and 

generating the menu Items of the dropdown 
menu in a language specified by the current us- 
er interface language setting. 

25 8. The method of Claim 7, wherein generating the 
menu Items of the dropdown menu comprises: 

generating menu items enabled for use with all 
languages; and 
^ generating menu items enabled for use with the 

language specified by the cunrent user interface 
language setting. 

9, The method of Claim 8, further comprising dlsplay- 
35 ing the number and an Indication that the numt>er 
has been semanticdily labeted, and wherein the (1st 
of actions Is provided in response to the selection 
of the number or the Indication. 



invention resides in the claims hereinafter appended. 



Claims 

1. In a system for creating and editing an electronic 
document, a method for converting a number be- 
tween two systems of measurement, the method 
comprising: 

determining whether a string of text contained 
within the electronic document contains a 
number having an associated unit name; 
In response to determining that the string of text 
includes a number having an associated unit 
name, semantically labeling the number with 
schema information identifying the unit name 
as a source unit of measure; 
providing a list of actions that may be perfonmed 
on the numt>er to convert the number to a des- 
tination unit of measure, the list of actions iden- 
tified based upon the schema information; 
receiving a selection of an action from the list 
of actions; and 

generating a converted number by converting 
the number from the source unit of measure to 
the destination unit of measure identified by the 
selected action. 

2. The method of Claim 1, wherein operating a con- 
verted number by c^verting the number from the 
source unit of measure to the destination unit of 
measure identified by the selected action compris- 
es: 

retrieving from a conversion settings file a con* 
version ratio or fonnula corresponding to the 
selected action; and 

generating a converted number by converting 
the number from tlie source unit of measure to 
the destination unit of measure with the conver- 
sion ratio or formula. 

3. The method of Claim 2, wherein the conversion set- 
tings file comprises a conversion ratio or formula 
corresponding to one or more measurement con- 
versions, and wherein the method further compris- 
es receiving from a user a user-defined conversion 
ratio or formula and storing the user-defined ratio 
or formufa in the conversion settings file. 

4. The method of Claim 1 , further comprising: 

replacing the number and the associated unit 
name with the converted number and a unit 
name associated with the destination unit of 
measure. 



40 10. The method of Claim 9, wherein the schema infor- 
mation comprises data uriiquety corresponding to 
the source unit of measure and the language spec- 
ified by the cun-ent user interface language setting. 

45 11. The method of Claim 10, further comprising: 

detentiinlng a value of the number prior to con- 
verting the number t)ased upon a format asso- 
ciated with the language In which the string of 
so text is expressed. 

12. A computer-readable medium comprising compu- 
ter-readable instructions which, when executed by 
a computer, cause the computer to perform the 

55 method of Claim 2. 

13. A computer-controlled apparatus capable of per- 
fomiing the method of Claim 2. 



45 11. 
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14. in a system for creating and editing an electronic 
document, a method for converting a number be- 
tween two systems of measurement, tfie method 
comprising: 

receiving a portion of the electronic document 
as a string of text; 

analyzing the string of text to determine wheth> 
er the string of text includes a number having 
an associated unit nanne; 
in response to detemiining that the string of text 
Includes a number having an associated unit 
name, semantically labeling the number with 
schema infomiatlon identifying the unit name 
as a source of measure; 
displaying the number and the unit name and 
an indication that the number has been seman- 
tically labeled; 

receiving a selection of the number or the Indi- 
cation; 

in response to receiving the selection of the 
number or the indication, providing a fist of ac- 
tions that may be performed on the number to 
convert the number to a destination unit of 
measure; 

receiving the selection of an action from the list 
of actions; 

In response to receiving the selection of an ac- 
tion, detennining a value for the number based 
upon a format associated with a language in 
which the string of text is expressed; 
generating a converted number by converting 
the value to the destination unit of nrteasure 
identified by the selected action; and 
replacing the number with the converted 
number in the string of text 

15. The method of Claim 14, wherein the list of actions 
comprises a dropdown menu having one or more, 
menu items corresponding to the list of actions that 
may be performed on the number to convert the 
number to the destination unit of measure. 

16. The method of Claim 15, further comprising: 

detemruning a current user Interface language 
setting tor an application program associated 
with the electronic document; and 
generating the menu items of the dropdown 
menu in a language specified by the current us- 
er interface language setting, 

17. The method of Claim 16, wherein generating the 
menu items of the dropdown menu corriprises: 

generating menu items enabled for use with all 
languages: and 

generating menu items enabled for use with the 



language epecified by the current user interface 
language setting. 

18. A computer*readable medium comprising compu- 
5 ter-readable instmcHons which, when executed by 

a computer, cause the computer to perfomn the 
method of Claim 14. 

19. A computer-oontrolied apparatus capable of per- 
10 forming the method of Claim 1 4. 

20. A system for converting a number between two sys- 
tems of measurement, the system comprising: 

IS a recognizer plug-in capable of receiving a por- 

tion of an electronic document as a string of text 
from an application program, analyzing the 
string of text to determine whether the string of 
text includes a number having an associated 
20 unit name, and In response to detennining tfiat 

the string of text indud&s a number having an 
associated unit name, semantically labeling the 
nurrtber with schema information Identifying the 
unit name as a source unit of measure and 
2S Identifying the language used to express the 

string of text; 

an application program for creating and editing 
the electronic document, the application pro- 
gram capable of displaying the string of text and 
30 an indication that the number has been seman- 

tically labeled, receiving a selection of the 
number or the indication. In response to receiv- 
ing the selection of the number or the indica- 
tion, providing a list of actions that may be per- 
35 f omned on the number to convert the number to 

a destination unit of measure, receiving the se- 
lection of an action from the list of actions, and 
providing the selected action and the number 
to an action plug*in; and 
40 an action plug-in capable of generating a con- 

verted number by converting the number to the 
destination unit of measure identified by the se- 
lected action, and replacing the number with 
the converted number and a unit name corre- 
45 spending to the destination unit of measure in 

the string of text. 

21. The system of Claim 20, wherein the list of actions 
comprises a dropdown menu leaving one or more 

so menu items corresponding to the list of actions that 
may be performed on the number to convert the 
number to the destination unit of measure, and 
wherein the action plug-in is further operative to: 

55 determine a current user Interface language 

setting for the application program; and to 
generate the menu items of the dropdown 
menu in a language specified by the current us- 
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er Interfaoe language setting. 

22» The system of Claim 21 , wherein the action plug-in 
is further operative to identify one or nrK>re enabled 
languages for the application program and to gen- 
erate menu items enabled for use with all languag- 
es, and to generate menu \iea\s enabled for use 
with the language specified by the current user in- 
terface language setting. 
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